# 四位元加法器電路

(Data Flow Modeling-I)

電子實驗

組別:第三組

系級:資訊二乙

組員 1:10927202 陽彩柔

組員 2:10927207 蒲品憶

組員 3:10927248 連翊安

### Part1

## (1)程式碼

#### FA.v

```
1
     `timescale lns/lns
 2
      module FA(a, b, c, cout, sum) ;
 3
       input a, b, c;
 4
 5
       output cout, sum ;
 6
 7
       wire el, e2, e3;
 8
       assign el = a & b ;
       assign e2 = a & c ;
 9
10
       assign e3 = b & c;
11
       assign cout = e1 | e2 | e3;
12
       assign sum = a ^ b^ c;
13
14
     endmodule
```

#### HA.v

```
1  | 'timescale lns/lns
2  module HA(a, b, c, cout, sum);
3
4  input a, b, c;
5  output cout, sum;
6
7  assign sum = a ^ b;
8  assign cout = a & b;
9
10
11  endmodule
```

## (2)模擬 waveform



### Part3

# (1)程式碼

## RCA4.v

```
module RCA4(a, b, cout, s);
 2
 3
      input [3:0] a, b;
 4
      output [3:0] s;
 5
      output cout ;
 7
     wire [4:0] at, bt;
8
      wire [4:0] st ;
9
10
     assign at = {1'b0, a};
11
     assign bt = \{1'b0, b\};
12
     assign st = at + bt ;
13
      assign s = st[3:0];
14
      assign cout = st[4:4] ;
15
16
    endmodule
```

## TM\_RCA4.v

```
module TM RCA4 ;
      reg [3:0] a, b;
 3
       wire [3:0] s ;
 4
       wire cout ;
       RCA4 U_RCA4( .a(a), .b(b),.s(s), .cout(cout));
8
       initial
       begin
       a = 4'b00000;
10
        b = 4'b00000;
11
       # 200
13
         a = 4'b0001;
14
         b = 4'b0011;
15
16
17
        # 200
        a = 4'b0010 ;
18
19
         b = 4'b0101 ;
20
        # 200
21
         a = 4'b0101 ;
        b = 4'b0011;
23
```

```
24
        # 200
25
26
          a = 4'b0110 ;
          b = 4'b0111 ;
27
28
29
          # 200
          a = 4'b0111 ;
30
          b = 4'b0001;
32
33
           # 200
          a = 4'b1001;
b = 4'b1011;
34
35
37
         # 200
          a = 4'b1000;
b = 4'b1101;
38
39
40
         # 200
41
         a = 4'b1010;
b = 4'b1001;
42
43
44
45
46
         # 200
          a = 4'b1011;
b = 4'b1101;
47
48
49
         # 200
          a = 4'blll1;
b = 4'blll1;
51
52
53
         # 200
54
     $stop ;
55
56
57
       end
58 endmodule
```

## (2)模擬 waveform

